<!DOCTYPE html>
<html>
<head>
<title>git命令</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css">
/* GitHub stylesheet for MarkdownPad (http://markdownpad.com) */
/* Author: Nicolas Hery - http://nicolashery.com */
/* Version: b13fe65ca28d2e568c6ed5d7f06581183df8f2ff */
/* Source: https://github.com/nicolahery/markdownpad-github */

/* RESET
=============================================================================*/

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
}

/* BODY
=============================================================================*/

body {
  font-family: Helvetica, arial, freesans, clean, sans-serif;
  font-size: 14px;
  line-height: 1.6;
  color: #333;
  background-color: #fff;
  padding: 20px;
  max-width: 960px;
  margin: 0 auto;
}

body>*:first-child {
  margin-top: 0 !important;
}

body>*:last-child {
  margin-bottom: 0 !important;
}

/* BLOCKS
=============================================================================*/

p, blockquote, ul, ol, dl, table, pre {
  margin: 15px 0;
}

/* HEADERS
=============================================================================*/

h1, h2, h3, h4, h5, h6 {
  margin: 20px 0 10px;
  padding: 0;
  font-weight: bold;
  -webkit-font-smoothing: antialiased;
}

h1 tt, h1 code, h2 tt, h2 code, h3 tt, h3 code, h4 tt, h4 code, h5 tt, h5 code, h6 tt, h6 code {
  font-size: inherit;
}

h1 {
  font-size: 28px;
  color: #000;
}

h2 {
  font-size: 24px;
  border-bottom: 1px solid #ccc;
  color: #000;
}

h3 {
  font-size: 18px;
}

h4 {
  font-size: 16px;
}

h5 {
  font-size: 14px;
}

h6 {
  color: #777;
  font-size: 14px;
}

body>h2:first-child, body>h1:first-child, body>h1:first-child+h2, body>h3:first-child, body>h4:first-child, body>h5:first-child, body>h6:first-child {
  margin-top: 0;
  padding-top: 0;
}

a:first-child h1, a:first-child h2, a:first-child h3, a:first-child h4, a:first-child h5, a:first-child h6 {
  margin-top: 0;
  padding-top: 0;
}

h1+p, h2+p, h3+p, h4+p, h5+p, h6+p {
  margin-top: 10px;
}

/* LINKS
=============================================================================*/

a {
  color: #4183C4;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

/* LISTS
=============================================================================*/

ul, ol {
  padding-left: 30px;
}

ul li > :first-child, 
ol li > :first-child, 
ul li ul:first-of-type, 
ol li ol:first-of-type, 
ul li ol:first-of-type, 
ol li ul:first-of-type {
  margin-top: 0px;
}

ul ul, ul ol, ol ol, ol ul {
  margin-bottom: 0;
}

dl {
  padding: 0;
}

dl dt {
  font-size: 14px;
  font-weight: bold;
  font-style: italic;
  padding: 0;
  margin: 15px 0 5px;
}

dl dt:first-child {
  padding: 0;
}

dl dt>:first-child {
  margin-top: 0px;
}

dl dt>:last-child {
  margin-bottom: 0px;
}

dl dd {
  margin: 0 0 15px;
  padding: 0 15px;
}

dl dd>:first-child {
  margin-top: 0px;
}

dl dd>:last-child {
  margin-bottom: 0px;
}

/* CODE
=============================================================================*/

pre, code, tt {
  font-size: 12px;
  font-family: Consolas, "Liberation Mono", Courier, monospace;
}

code, tt {
  margin: 0 0px;
  padding: 0px 0px;
  white-space: nowrap;
  border: 1px solid #eaeaea;
  background-color: #f8f8f8;
  border-radius: 3px;
}

pre>code {
  margin: 0;
  padding: 0;
  white-space: pre;
  border: none;
  background: transparent;
}

pre {
  background-color: #f8f8f8;
  border: 1px solid #ccc;
  font-size: 13px;
  line-height: 19px;
  overflow: auto;
  padding: 6px 10px;
  border-radius: 3px;
}

pre code, pre tt {
  background-color: transparent;
  border: none;
}

kbd {
    -moz-border-bottom-colors: none;
    -moz-border-left-colors: none;
    -moz-border-right-colors: none;
    -moz-border-top-colors: none;
    background-color: #DDDDDD;
    background-image: linear-gradient(#F1F1F1, #DDDDDD);
    background-repeat: repeat-x;
    border-color: #DDDDDD #CCCCCC #CCCCCC #DDDDDD;
    border-image: none;
    border-radius: 2px 2px 2px 2px;
    border-style: solid;
    border-width: 1px;
    font-family: "Helvetica Neue",Helvetica,Arial,sans-serif;
    line-height: 10px;
    padding: 1px 4px;
}

/* QUOTES
=============================================================================*/

blockquote {
  border-left: 4px solid #DDD;
  padding: 0 15px;
  color: #777;
}

blockquote>:first-child {
  margin-top: 0px;
}

blockquote>:last-child {
  margin-bottom: 0px;
}

/* HORIZONTAL RULES
=============================================================================*/

hr {
  clear: both;
  margin: 15px 0;
  height: 0px;
  overflow: hidden;
  border: none;
  background: transparent;
  border-bottom: 4px solid #ddd;
  padding: 0;
}

/* TABLES
=============================================================================*/

table th {
  font-weight: bold;
}

table th, table td {
  border: 1px solid #ccc;
  padding: 6px 13px;
}

table tr {
  border-top: 1px solid #ccc;
  background-color: #fff;
}

table tr:nth-child(2n) {
  background-color: #f8f8f8;
}

/* IMAGES
=============================================================================*/

img {
  max-width: 100%
}
</style>
</head>
<body>
<h1>git命令</h1>
<h3>何谓同步远程分支？有两种情况，</h3>
<pre><code>1.本地有新分支，远程仓库没有。

2.远程仓库有新分支，本地没有。

3.本地删除了分支，远程也想删除。

4.远程删除了分支，本地也想删除。
</code></pre>

<p>第一种情况很好解决，将本地分支推送到远程仓库即可。</p>
<p>本文主要讲解后面几种情况的解决办法。</p>
<hr />
<h3>1.第二种情况：远程仓库有新分支，本地没有。</h3>
<p>这在之前我先介绍几个命令。</p>
<pre><code>1.将某个远程主机的更新，全部取回本地：git fetch

2.查看远程分支：git branch -a

3.查看本地分支：git branch

4.切换分支：git checkout 分支
</code></pre>

<p>熟悉了以上命令，接下来我们通过一个例子来讲解第二种情况的解决办法。</p>
<blockquote>
<p>假如我本地有个git仓库，别人推送了一个新分支到远程仓库，我要获取这个分支到本地，该怎么办？</p>
</blockquote>
<pre><code>1.我需要git branch查看一下本地分支，再git branch -a查看一下远程分支，对比下，远程存在哪些本地没有的新分支。但发现，本地和远

程的一样。奇怪，在远程仓库（gitlab/github）明明看到了新分支啊。 
</code></pre>

<p><strong>原来现在本地上的现在的远程分支记录是克隆仓库时当时的分支记录。</strong>所以我需要</p>
<pre><code>1.首先将某个远程主机的更新，全部取回本地：git fetch

2.再次查看远程分支：git branch -a 发现远程的分支已经可以看见了。

3.然后拉取远程分支到本地：git checkout -b 远程分支名 origin/远程分支名
</code></pre>

<p><strong>注：直接克隆整个仓库，可以直接使用git checkout 分支名切换到分支。因为克隆时候已经有远程所有的分支记录。但若之前已经克隆过，后来其他电脑新push一个分支，此时是无法切换到新分支的。使用上述命令可拉取最新分支（原理是在本地新建一个分支和远程分支关联起来）</strong></p>
<hr />
<h3>2.第三种情况：本地删除了分支，远程也想删除。</h3>
<p>这在之前我先介绍几个命令。</p>
<pre><code>1.删除远程分支: git push origin -d 分支名

2.删除本地分支: git branch -d 分支名
</code></pre>

<p>熟悉了以上命令，接下来我们通过一个例子来讲解第三种情况的解决办法。</p>
<blockquote>
<p>假如我在本地想要删除某个分支，我也想把远程仓库的这个分支也要删掉怎么办？</p>
</blockquote>
<pre><code>1.使用git branch -d 分支名来删除本地分支。
2.使用git push origin -d 分支名直接来删除远程分支。在次使用git branch -a,发现分支已经不存在了。

或者
1.使用git branch -d 分支名来删除本地分支。
2.最简单的解决办法就是直接到gitlab/github进行删除.
</code></pre>

<blockquote>
<p>假如我只想把远程的删除掉怎么办？</p>
</blockquote>
<pre><code>1.使用git push origin -d 分支名直接来删除远程分支。此时删除的只是远程的分支，本地仍然存在

或者

1.直接到gitlab/github进行删除.
</code></pre>

<hr />
<h3>3.第四种情况：远程删除了分支，本地也想删除。。</h3>
<p>这在之前我先介绍几个命令。</p>
<pre><code>1.查看远程分支和本地分支的对应关系:git remote show origin  

2.删除远程已经删除过的分支:git remote prune origin
</code></pre>

<p>熟悉了以上命令，接下来我们通过一个例子来讲解第四种情况的解决办法。</p>
<blockquote>
<p>假如我直接到gitlab/github删除了某个分支，我在本地使用git branch -a查看远程分支，依然存在并且可以切换使用。我本地也想把远程分支记录删除怎么办？</p>
</blockquote>
<pre><code>1.git branch -a查看远程分支，红色的是本地远程远程分支记录。

2.执行下面命令查看远程仓库分支和本地仓库的远程分支记录的对应关系：

  git remote show origin  

3.会看到：

 refs/remotes/origin/远程仓库已经删除的分支名              stale (use 'git remote prune' to remove)

 其中：

 Local refs configured for 'git push':  命令下面的分支是本地仓库的远程分支记录中仍存在的分支，但远程仓库已经不存在。

4.输入git remote prune origin来删除远程仓库已经删除过的分支

5.验证 git branch -a

  此时可以看到本地远程分支记录已经和远程仓库保持一致了。
</code></pre>

<blockquote>
<p>实际测试截图</p>
</blockquote>
<p><img src="https://i.imgur.com/AAQ1Unm.png" /></p>
<p><img src="https://i.imgur.com/X09TC5x.png" /></p>
<p><img src="https://i.imgur.com/2lSRSG3.png" /></p>

</body>
</html>
<!-- This document was created with MarkdownPad, the Markdown editor for Windows (http://markdownpad.com) -->
